home *** CD-ROM | disk | FTP | other *** search
/ Aminet 1 (Walnut Creek) / Aminet - June 1993 [Walnut Creek].iso / aminet / os20 / gfx / fastlife_2_2.lzh / FastLife2.2 / ReqTools / README < prev    next >
Text File  |  1992-12-19  |  34KB  |  657 lines

  1.  
  2.                       **********************************
  3.  
  4.                           reqtools.library
  5.  
  6.                           The requester toolkit.
  7.  
  8.                           Release 2.1a
  9.  
  10.                           (c) 1991/1992 Nico François
  11.  
  12.                       **********************************
  13.  
  14.  
  15.    First of all read the DISTRIBUTION file for information on... er well...
  16. distribution :-)
  17.  
  18.    If you have suggestions or remarks about ReqTools, or if you find any
  19. bugs, please let me know.
  20.  
  21.    Contacting the author:
  22.  
  23.      Fido:  2:292/603.10 (Nico Francois)
  24.  
  25.      UUCP:  Nico.Francois@p10.f603.n292.z2.FidoNet.Org
  26.  
  27.      Mail:  Nico François
  28.             Corbielaan 13
  29.             B-3060 Bertem
  30.             BELGIUM
  31.  
  32.    If you can please use e-mail.  That way you'll stand a much better chance
  33. of getting a reply quickly.
  34.  
  35.  
  36. Contents
  37. ========
  38.  
  39. 1. Introduction
  40.  
  41. 2. Features
  42.  
  43. 3. Installation
  44.  
  45. 4. Using reqtools.library
  46.  
  47.  
  48. 1. Introduction
  49. ===============
  50.  
  51.     reqtools.library is a standard Amiga shared, runtime library.  The purpose
  52. of ReqTools is to make it a lot quicker and easier to build standard requesters
  53. into your programs.  ReqTools is designed with Commodore's style guidelines in
  54. mind, all requesters have the look-and-feel of AmigaDOS Release 2.
  55.  
  56.     If you use ReqTools in your programs you do not have to worry about
  57. requesters too much.  You'll have a lot more time to concentrate on the
  58. really important stuff your program does.
  59.  
  60.     The library has been inspired by req.library (by Colin Fox & Bruce Dawson)
  61. and Commodore's own asl.library.  You will find it shares a lot of the
  62. features with these two libraries, while it has some additional ones as well.
  63. While asl.library was great in look-and-feel I felt it lacked quite a bit in
  64. the power department.  This power _is_ mostly available in req.library, but
  65. this doesn't fit in too well with AmigaDOS Release 2.  So the idea for a new
  66. requester library was born.
  67.  
  68.     I tried to make all requesters in ReqTools very powerful, easy to use and 
  69. with a very nice new-look 3D interface.  Efficiency was also considered very
  70. important.  The 2.0 version of the library is about 37K large.  I'm sure you
  71. will agree this is not too much considering what ReqTools offers.
  72.  
  73.     ReqTools features the following requesters:  a query requester, a string
  74. requester, a number requester, a file requester, a font requester, a palette
  75. requester and new in release 2.0 of ReqTools a volume requester and a screen
  76. mode requester.
  77.  
  78.  
  79. 2. Features
  80. ===========
  81.  
  82.    The requesters have following features (features marked with *NEW* are new
  83. features for release 2.0, version 38 of ReqTools).
  84.  
  85.    All requesters:
  86.  
  87.       o have a pixel-perfect Workbench 2.0 3D look, also on Kickstart 1.3.
  88. *NEW* o Completely localized!  If you are using Workbench 2.1 or higher the
  89.         text in ReqTools requesters will appear in the language of your
  90.         Workbench (if the catalog for this language is available).
  91.       o adjust to interlaced screens and to the screen's font (rtEZRequest,
  92.         rtGetLong, rtGetString) or to any fixed-width font if the screen's
  93.         font is proportional (rtPaletteRequest/rtFileRequest/rtFontRequest).
  94. *NEW*   Requesters can also use any suitable font you specify.
  95.       o can appear under the mouse pointer, centered on the
  96.         screen/in a window or at the top left of the screen/a window.
  97.       o can be used asynchronously.
  98.       o check pr_WindowPtr of your process is to find the screen they should
  99.         appear on (can be overridden).
  100.       o use tags for maximum future extendibility.  All standard 2.0 tags are
  101.         supported (like TAG_SKIP, TAG_MORE, etc.).
  102.       o bring the screen they appear on to the front.  The screen that was
  103.         in front previously will be put in front again when the requester
  104.         finishes (if it is still open).
  105. *NEW*   This behaviour can be switched off.
  106.       o will always appear in the visible portion of the screen (support of
  107.         virtual screens).
  108.       o are extensively tested using enforcer and mungwall debugging tools.
  109. *NEW* o have the ability to lock the parent window from all user input and
  110.         give it a standard wait pointer automatically.
  111. *NEW* o can share the IDCMP port of the parent window.
  112. *NEW* o supports a callback hook for handling IDCMP messages from a shared
  113.         IDCMP port.
  114. *NEW* o have keyboard shortcuts for gadgets (key underlined in gadget label).
  115.         Use Right Amiga key with shortcut if a string gadget is active.
  116.  
  117.    rtEZRequest, the query requester:
  118.  
  119.       o easy keyboard shortcuts:
  120.         - Left Amiga V and Left Amiga B (like the standard requesters).
  121.         - Y for positive response.
  122.         - N, R, Esc for negative response.
  123.         - Return can also be used as a shortcut and can be
  124.           associated with any response.  The gadget in question
  125.           will have its text printed bold.
  126.           Default response for Return is the positive response.
  127.         - buttons give visual feedback when keyboard shortcuts
  128.           are used.
  129.         - keyboard shortcuts can be canceled by pressing Shift
  130.           before releasing the key.
  131. *NEW*   - keyboard shortcuts can be defined to be any character in the
  132.           button's label.  The character in question will be underlined.
  133.       o number of responses only limited by screen width.
  134.       o allows for multiple lines of text.
  135.       o text can be centered in requester (great for about requesters).
  136.       o supports the use of 'printf' formatting codes in text
  137.         and in responses.
  138.       o can be terminated by IDCMP events.
  139.  
  140.    rtFileRequest, the file requester:
  141.  
  142.       o similar in use and look-and-feel as Asl file requester.
  143.       o buffers directories in memory.
  144.       o files and directories can be added or removed from the buffer
  145.         by the calling program.
  146.       o can be put in save mode, disabling double-clicks and asking you if
  147.         directories that can't be found (entered manually) should be created.
  148.       o optional callback hook for verification of files before they are
  149.         added to the buffer.
  150.       o supports multiple selection of files and optionally of directories.
  151.       o when multi-select is on All, Clear and Match.. buttons are available.
  152.         All selects, and Clear unselects all files.  Match.. brings up a
  153.         requester where the user can enter a pattern to select files.
  154.       o can be used as a directory requester (showing no files).
  155.       o optional pattern gadget to match files on.
  156.       o shows all devices (with volume names) and all assigns made.
  157.       o supports TABCYCLE under 2.0
  158.       o pattern matching supports _ALL_ AmigaDOS 2.0 patterns.
  159. *NEW* o can be used as a volume requester to get a device or an assign
  160.         from the user.
  161. *NEW* o can be resized in height to show more files.
  162. *NEW* o Shows disk percentage used next to volume names.
  163. *NEW* o Allows you to enter paths in the filename string gadget.  If the
  164.         requester finds a path in the filename it will change the directory
  165.         to that path.  So if you e.g. enter 'Devs:mountlist' in the filename
  166.         gadget the requester will read the 'Devs:' directory and set the
  167.         filename gadget to 'mountlist'.  If you enter 'printers/' it will go
  168.         into the printers directory. Enter '/' to go to the parent directory.
  169. *NEW* o Completely keyboard controlable: use up and down cursor keys to
  170.         select files or directories.  Use Shift-Up and Shift-Down to jump
  171.         by one window-full.  Use Ctrl-Up and Ctrl-Down to jump to the start
  172.         or end of the directory.
  173.  
  174.    rtFontRequest, the font requester:
  175.  
  176.       o buffers all fonts in memory.
  177.       o shows sample of font you click on.
  178.       o can be also be used to select the font's style.
  179.       o supports color fonts, can change the screen's palette.
  180.       o supports scaled fonts (AmigaOS Release 2 only).
  181.       o optional callback hook for verification of fonts before they are
  182.         added to the buffer.
  183.       o supports TABCYCLE under 2.0
  184. *NEW* o can be resized in height to show more fonts.
  185. *NEW* o makes sure selected font is visible in listview when it comes up.
  186.  
  187. *NEW* rtScreenModeRequest, the display mode requester (Kickstart 2.0+ only!):
  188.  
  189. *NEW* o all modes in the DisplayInfo database can be displayed.
  190. *NEW* o allows you to pick a standard overscan setting.
  191. *NEW* o user may enter prefered size or choose to get the defaults.
  192. *NEW* o number of colors selectable.
  193. *NEW* o can be put up with the attributes from a given screen.
  194. *NEW* o optional callback hook for examining a display mode before it is
  195.         added to the requester.
  196. *NEW* o can be resized in height to show more modes.
  197. *NEW* o makes sure selected mode is visible in listview when it comes up.
  198.  
  199.    rtPaletteRequest, the palette requester:
  200.  
  201.       o features Copy, Swap and Spread functions.
  202.       o current values of red, green and blue are displayed.
  203.       o returns the selected color.
  204.  
  205.    rtGetLong, the long integer requester:
  206.  
  207.       o width of requester can be set by caller.
  208.       o a minimum and maximum can be supplied and will be displayed
  209.         in the requester.
  210.       o a value to show up when the requester appears can be supplied.
  211. *NEW* o can display buttons with several possible responses.
  212. *NEW* o invisible entry is possible (useful for getting a code number).
  213. *NEW* o patterned backfill of requester can be switched on or off.
  214. *NEW* o some line(s) of (centered) text may be displayed above the entry
  215.         gadget to give the user some extra information.
  216.  
  217.    rtGetString, the string requester:
  218.  
  219.       o width of requester can be set by caller.
  220.       o a string to show up when the requester appears can be supplied.
  221. *NEW* o can display buttons with several possible responses.
  222. *NEW* o invisible entry is possible (useful for getting a password).
  223. *NEW* o patterned backfill of requester can be switched on or off.
  224. *NEW* o some line(s) of (centered) text may be displayed above the entry
  225.         gadget to give the user some extra information.
  226.  
  227.  
  228. 3. Installation
  229. ===============
  230.  
  231.    To install reqtools.library copy it to your Libs: directory by hand, or
  232. run the installation script 'Install' (by using 'Execute' from the Shell or
  233. by double-clicking its icon).
  234.  
  235.    reqtools.library is provided in two versions (that are 100% equivalent,
  236. meaning you don't have to care which version the user installed):  one for
  237. Kickstart 1.2 (or higher) and one for Kickstart 2.0 and higher.
  238.  
  239.    The version for Kickstart 2.0 uses 2.0 ROM functions for stuff like
  240. pattern matching, parsing tags, the 3D look, while a lot in the Kickstart 1.3
  241. version is emulated.  It issuggested you use the 2.0 version of the library if
  242. you have Kickstart 2.0 in ROM.
  243.  
  244.    If you are running Workbench 2.1 or higher you will have the possiblity to
  245. use ReqTools in different languages.  Just use the appropriate install script
  246. in the Install/Workbench_2.1+ directory.
  247.  
  248.  
  249. 4. Using reqtools.library
  250. =========================
  251.  
  252.    If you are a C programmer all you need to do is include the correct
  253. header ('libraries/reqtool.h') and open reqtools.library. After that you can
  254. use the functions in the library as if they were C functions. If your program
  255. quits it must of course close the library again. See 'demo.c' for an example.
  256.  
  257.    Glue code for several compilers/languages is included with ReqTools 2.1.
  258. Look in the Glue directory of the ReqTools distribution to see if glue code
  259. exists for your compiler and/or programming language.  If it doesn't and you
  260. write your own please send it to me and I'll include it in the next release
  261. of ReqTools.
  262.     Note that the source for the Manx C libraries is the same as for the SAS/C
  263. libraries.  See the README.Manx file in the archive
  264. 'Glue/Sas-C/LibSource.lha'.
  265.  
  266.    Functions allowing a variable number of arguments can't be called using
  267. pragmas (in-line library calls, no glue code required).  So if you use these
  268. you must always link with LIB:reqtools.lib or LIB:reqtoolsnb.lib (for SAS-C,
  269. or with the specific libraries for your compiler/language).
  270.  
  271.    Assembly programmers should also include the correct files and open
  272. reqtools.library.  To call a function they must load A6 with the library base,
  273. put the arguments in the appropriate registers and jump to the library vector
  274. offset of the function they want to call.
  275.  
  276.    Remember to open the library with a specific version number if you wish to
  277. use features only found in that version (for example: screen mode requester).
  278.  
  279.    All library functions are explained in the autodoc file 'reqtools.doc'.
  280.  
  281.                                                        Enjoy.
  282.  
  283.  
  284.                                LIBRARY HISTORY:
  285.  
  286. *****************************************************************************
  287. RELEASE 1.0 (Library version 37.556 [1.3] - 37.670 [2.0])
  288.  
  289.     First release.
  290.  
  291. *****************************************************************************
  292. RELEASE 1.0a (Library version 37.557 [1.3] - 37.673 [2.0])
  293.  
  294.     Fixed two minor bugs:
  295.       - if a directory could not be found and you re-invoked the file
  296.         requester it wouldn't check the directory again.
  297.       - devices like PRT:, CON:, etc. now no longer show up in the device
  298.         list of the 2.0 file requester.
  299.  
  300. *****************************************************************************
  301. RELEASE 1.0b (Library version 37.566 [1.3] - 37.678 [2.0])
  302.  
  303.     Fixed bug: entering a pattern when a file requester's directory was
  304.       invalid could cause a crash.
  305.     rtGetString() and rtGetLong() 2.0 requester windows no longer have close
  306.       gadgets.
  307.     Font requester entries are "release verify" instead of "immediate".
  308.     If no minimum or maximum is given for the GetLong requester it will not
  309.       be displayed (1.0 and 1.0a displayed MAXINT or MININT).
  310.     Minor cosmetic adjustments to file, font and palette requesters.
  311.     Oberon interface to the library included.
  312.  
  313. *****************************************************************************
  314. RELEASE 1.0c (Library version 37.592 [1.3] - 37.718 [2.0])
  315.  
  316.     Boopsi dispatch function for rtEZRequestA() buttons optimized (ReqTools
  317.       for Kickstart 2.0).  Occasional flicker just about eliminated.
  318.     Enlarged buttons a bit in rtGetLongA(), rtGetStringA() and the file, font
  319.       and palette requesters.
  320.     Width of scroller gadget in file requester window increased.
  321.     File string gadget is cleared when 'All' or 'Match..' is used.  This
  322.       wasn't done before and could result in unexpected multi-select results.
  323.     Visual feedback for keyboard shortcuts improved (rtEZRequestA()).  Button
  324.       stays depressed as long as the key in question is held down, but still
  325.       for a minumum of 1/10 sec.  New feature:  shortcuts can be canceled by
  326.       pressing Shift before releasing the key.
  327.     Minor bug fix: keyboard shortcuts V and B now really only work together
  328.       with the Left Amiga key.  Used to work without the qualifier.
  329.     rtEZRequestA(), rtGetLongA() and rtGetStringA() will no longer call the
  330.       DOS function Delay(), so they may from now on be called by tasks.
  331.       Every ReqTools requester, except the file and font requesters (they use
  332.       DOS for obvious reasons), can be called from a task.
  333.     EZRequest with only one button now responds to the Return key, whether
  334.       EZREQF_NORETURNKEY is set or not.
  335.     Fixed small bug in libraries/reqtools.i include file.  rtfi_Hook and
  336.       rtfo_Hook were followed by a ; and this could lead to problems.
  337.     Libraries (reqtoolss.lib and reqtoolssr.lib) for Dice C included.
  338.     Pre-release (0.91ß) of RTPatch patcher program included.
  339.  
  340. *****************************************************************************
  341. RELEASE 1.0d (Library version 37.600 [1.3] - 37.726 [2.0])
  342.  
  343.     rtEZRequestA(), rtGetStringA() and rtGetLongA() now switch the processor
  344.       stack to ensure sufficient stack space for the function to succeed.
  345.     Fixed bug in rtGetLong() requester in 2.0 version of ReqTools.  Used to
  346.       return TRUE and a random value if the user pressed Ok when the integer
  347.       gadget was empty.
  348.     File requester is somewhat larger by default.
  349.     Improved automatic requester resizing (if requester would become too big
  350.       for the screen).
  351.     File requester (in save mode) no longer asks "Create drawer?" when you
  352.       entered a drawer string containing a non-existing volume (e.g. 'FOO:').
  353.     Entries in file requester are now sorted immediately when you select the
  354.       slider gadget and not when you release it (1.3 version of ReqTools).
  355.     Latest revision of Oberon interface included.
  356.     Modula-2 interface to the library included.
  357.     Manx C interface to the library included.
  358.  
  359. *****************************************************************************
  360. RELEASE 1.0e (Library version 37.600 [1.3] - 37.726 [2.0])
  361.  
  362.     Rearranged directories a bit.  All glue code now in one directory.
  363.     Installation script now uses Commodore's Installer utility.
  364.     Two Modula-2 interfaces to the library are now included, one for M2Sprint
  365.       and one for M2Amiga.
  366.     Some bugs in the Dice C libs have been fixed (thanks to Magnus Holmgren).
  367.     Interface for HiSoft's HighSpeed Pascal included.
  368.  
  369. *****************************************************************************
  370. RELEASE 2.0 (Library version 38.347 [1.3] - 38.693 [2.0])
  371.  
  372.     All requesters now have keyboard shortcuts.
  373.     Kickstart 2.0 version of ReqTools has been localized.  As long as the
  374.       appropriate catalog file exists ReqTools will appear in the user's
  375.       selected langauge.
  376.     New requester: rtScreenModeRequestA().  A screen mode requester. Can be
  377.       used to get a screen mode, size, depth and overscan type from the user.
  378.       This requester is only available on Kickstart 2.0 or higher, but also
  379.       present in the Kickstart 1.3 version of ReqTools.
  380.     File, font and screenmode requesters are now resizable (in height).
  381.     Font, volume and screen mode requesters will now make sure the current
  382.       entry is visible in the listview when the requester first comes up.
  383.     Improved DOWILDFUNC hook interface.  New tag: RTxx_FilterFunc. Old hook
  384.       interface (using req->Hook and FREQF_DOWILDFUNC flag) is still
  385.       supported, but declared obsolete.  Don't use in new code.
  386.     Several new tags:
  387.       o RT_Locale:  specify a locale to be used instead of the default one.
  388.         Ignored if locale.library isn't present in the system or you are
  389.         using the Kickstart 1.3 version of ReqTools.
  390.       o RT_ShareIDCMP and RT_IntuiMsgFunc:  All requesters can now share
  391.         their IDCMP port with the parent window.  A callback hook for
  392.         intuition messages received not concerning the requester can also be
  393.         set using the RT_IntuiMsgFunc tag.
  394.       o RT_LockWindow:  Enables you to make ReqTools lock the parent window
  395.         from all user input and give the window a standard wait pointer.
  396.         After the requester returns the window will be unlocked and will get
  397.         its original pointer back.
  398.       o RT_Underscore:  With this tag it is possible to define keyboard
  399.         shortcuts for buttons.  You can ask ReqTools to underline a character
  400.         in the button's label and use this as a shortcut.
  401.       o for rtGetString() and rtGetLong(): RTGS_GadFmt, RTGS_GadFmtArgs,
  402.         RTGL_GadFmt and RTGL_GadFmtArgs.  With these tags you may give the
  403.         user several ways out of the string/long requester.
  404.       o for rtGetString() and rtGetLong(): RTGS_Invisible and RTGL_Invisible.
  405.         Can be used to switch on invisible typing to get a password or a code
  406.         number from the user.
  407.       o RTGS_TextFmt, RTGL_TextFmt, RTGS_TextFmtArgs and RTGL_TextFmtArgs:
  408.         These tags allow you to supply some line(s) of text that should be
  409.         printed above the string/integer gadget in the rtGetString() or
  410.         rtGetLong() requesters.
  411.       o RTGS_Flags and RTGL_Flags:  Set certain flags for rtGetString() and
  412.         rtGetLong() requesters.  Used to set the GSREQF_CENTERTEXT or
  413.         GLREQF_CENTERTEXT flags.
  414.       o RTGS_BackFill and RTGL_BackFill:  Switch the patterned backfill in
  415.         the rtGetString() and rtGetLong() requesters on or off.
  416.       o RT_ScreenToFront:  Allows you to switch of the default behaviour of
  417.         popping the screen the requester appears on to the front.
  418.       o RT_TextAttr:  Allows you to specify a font a requester should use
  419.         instead of the screen or default font.
  420.       o RTFI_VolumeRequest:  New flavor of file requester: volume requester.
  421.         Allows you to easily get a device/assign from the user.
  422.       o RTFI_AllowEmpty:  Enables you to allow the file requester to accept
  423.         an empty filename.  Normally cancels the requester if no filename
  424.         was entered.
  425.     Changes to file requester:
  426.       o Shows disk percentage used next to volume names.
  427.       o 'Hide .info' cycle gadget gadget in file requester replaced by
  428.         '.info' toggle gadget next to filename string gadget.
  429.       o Will no longer automatically change directories to their full
  430.         pathname.  Will only do so when needed (e.g. parent of an assign).
  431.       o Allows you to enter paths in the filename string gadget.  If the
  432.         requester finds a path in the filename it will change the directory
  433.         to that path.
  434.       o Completely keyboard controlable: use up and down cursor keys to
  435.         select files or directories.  Use Shift-Up and Shift-Down to jump
  436.         by one window-full.
  437.       o 1.3 version has a 2.0-look sizing gadget and bottom border.
  438.       o Changed 'Disks' to 'Volumes'.
  439.       o Changed '(dir)' to 'Drawer' (right justified).
  440.       o Assigns now displayed differently (with 'Assign' right justified).
  441.       o Added an indicator for number of selected files (if multiselect on).
  442.       o No longer shows 'Add', 'Match..' and 'Clear' gadgets if no multi-
  443.         select is possible.
  444.     New library functions:
  445.       o rtLockWindow() and rtUnlockWindow():  easily lock a window from user
  446.         input and give it a standard wait pointer.
  447.       o rtCloseWindowSafely():  close a window with a shared IDCMP port.
  448.     Updated glue code:
  449.       o Oberon interface updated for ReqTools V38.
  450.       o SAS/C, Manx C and Dice glue code updated for ReqTools V38.
  451.       o New HighSpeed Pascal (for ReqTools V38) interface written by
  452.         Gunter Indenhoek included.
  453.     Demo updated to demonstrate new features of ReqTools 2.0.
  454.     Version 1.0 of RTPatch patcher program included.  Patches req.library,
  455.       arp.library and asl.library to use ReqTools requesters instead.
  456.  
  457. *****************************************************************************
  458. RELEASE 2.0a (Library version 38.350 [1.3] - 38.693 [2.0])
  459.  
  460.     Aaaargh!  Just one day after releasing ReqTools 2.0 a MAJOR bug turned
  461.       up in the Kickstart 1.3 version:  rtLockWindow() was broken!!  Only
  462.       turned up when running on 1.3, since on 1.3 there seems to be no return
  463.       value from intuition.library/Request() (So C=, your autodocs have a bug
  464.       in them as well :-).  Bug fixed.
  465.     Fixed broken install script for Workbench 1.3.
  466.  
  467. *****************************************************************************
  468. RELEASE 2.0b (Library version 38.358 [1.3] - 38.803 [2.0])
  469.  
  470.     Installer is no longer distributed with ReqTools. It is copyrighted by
  471.       Commodore and can only be distributed under license. If you have
  472.       Installer (preferably version 2.12 or higher) make sure it is in your
  473.       command path so the install scripts will work. If you don't have
  474.       Installer you'll have to install ReqTools manually, sorry.
  475.     When you use the up/down arrows in the file requester and no file is
  476.       highlighted yet, ReqTools will now highlight the file at the top of
  477.       the visible area (instead of the first file in the list).
  478.     Some small changes in demo, now demonstrates min/max with rtGetLong(),
  479.       return value when RTGS_GadFmt is used and multi-selection in the file
  480.       requester.
  481.     Changed RTGL_BackFill and RTGS_BackFill tags to use the same spelling as
  482.       WA_BackFill in intuition.h (with a capital F).  Be sure to install the
  483.       new include files.
  484.     Install scripts for Workbench 2.0 or higher now also try to update
  485.       RTPatch (if the the file is found in C: or SYS:WbStartup).
  486.     Added icons for install scripts for all 10 languages.  Install strings
  487.       are all more or less translated.  Catalog translation files of all
  488.       languages not supported yet are now also included, making it easier to
  489.       translate ReqTools.
  490.     From this release on ReqTools will make sure the Dir field of the file
  491.       requester structure is pointing to the current directory while in the
  492.       file filter callback hook (RTFI_FilterFunc).
  493.     Changes in the Kickstart 2.0 version of ReqTools:
  494.       o All requesters use simple refresh windows.  Window refreshing is a
  495.         bit slower, but a lot of chip memory is saved.  Very important when
  496.         you use the requesters on screens with a lot of colors/bitplanes.
  497.       o All requesters have a backfill hook installed that will fill the
  498.         background of the window with the DrawInfo pen BACKGROUNDPEN.  The
  499.         DetailPen and BlockPen of the requesters will now also be set to
  500.         DrawInfo pens (BACKGROUNDPEN and SHADOWPEN).
  501.     Bug fixes:
  502.       o When the RTGL_GadFmt or RTGS_GadFmt tag was used the requester did
  503.         not return the correct value.
  504.       o Small problem with requester resizing on virtual screens. Maximum
  505.         number of entries was restricted to fit the visual area. The maximum
  506.         height of the requester's window is now also set correctly.
  507.       o Empty (current) directory no longer cancels the directory requester.
  508.       o Font requester in Kickstart 1.3 version of the library didn't
  509.         show a font if the font was previously opened in another height.
  510.       o Field rt_Flags in 'libraries/reqtools.[hi]' changed to rt_RTFlags
  511.         since it conflicted with the rt_Flags field in 'rexx/storage.[hi]'.
  512.         Shouldn't cause any problems since the field was private anyway.
  513.       o Entering a something like 'MAIL:/' to go to the parent directory
  514.         of MAIL: now works.
  515.     Some small errors and omissions fixed in the autodoc.
  516.     French catalog revised by David Lebel.  Thank you David for correcting
  517.       my lousy french :-)
  518.     Italian and Swedish catalog files included (thanks Michele and Patrik).
  519.     Updated/bug-fixed Oberon interface included.
  520.     Version 1.0a of RTPatch included.
  521.  
  522. *****************************************************************************
  523. RELEASE 2.0c (Library version 38.362 [1.3] - 38.810 [2.0])
  524.  
  525.     Fixed Enforcer hit in file, font and screenmode requesters of the
  526.       Kickstart 2.0 version of the library.
  527.     Fixed bug: when the pr_WindowPtr of the calling process was -1 and you
  528.       used a tag that needed a parent window (like RT_LockWindow or RT_ReqPos
  529.       with REQPOS_CENTERWIN) ReqTools could crash.
  530.     Pattern and drawer string gadgets no longer refresh the directory in the
  531.       requester if they aren't changed.  Especially useful if you cycle
  532.       through the string gadgets with TAB (Kickstart 2.0 version).
  533.     Included a README file explaining ReqTools' installation scripts need
  534.       Commodore's Installer utility.
  535.     Include file 'libraries/reqtools.h' fixed.  This used a BPTR without
  536.       including 'libraries/dos.h'. Thanks to Olaf Barthel for reporting this.
  537.     Danish catalog file included (thanks Per).
  538.     Version 1.0b of RTPatch included.
  539.  
  540. *****************************************************************************
  541. RELEASE 2.1 (Library version 38.382 [1.3] - 38.961 [2.0])
  542.  
  543.     New major feature: ReqTools preference editor (Kickstart 2.0+ only)!
  544.       o Switch screen to front popping on/off.
  545.       o Display drawers before files in file requester.
  546.       o Mix drawers and files in file requester.
  547.       o Sort entries in file requester immediately.
  548.       o Set default position of all requesters.
  549.       o Set default size of file, font, screenmode and volume requesters.
  550.       o Set minumum and maximum number of entries visible in file, font,
  551.         screenmode and volume requesters.
  552.     Kickstart 2.0 (or higher) version of ReqTools only:
  553.       o The file requester will keep its top entry up to date with what is
  554.         typed in the filename string gadget.  Pressing the up or down arrow
  555.         will select the file that most closely matches the contents of the
  556.         filename string gadget.
  557.       o Entering of pathnames in the filename string gadget has been
  558.         improved.  The file requester will now check if what you enter is a
  559.         directory.  This allows you to enter directories without a trailing
  560.         '/' (for example 'SYS:c').
  561.       o rtSetWaitPointer() and rtLockWindow() will set the standard Intuition
  562.         wait pointer on Kickstart 3.0 machines.  Note that rtUnlockWindow()
  563.         will _not_ restore the original pointer if it was a new pointerclass
  564.         pointer (Kickstart 3.0)!
  565.       o File requester is an AppWindow now.  This means you can drop disk,
  566.         drawer or file icons on the requester's window to go to a directory
  567.         or select a file.
  568.       o All requesters now set an appropriate bitplane write mask in the
  569.         rastport of their windows.  This makes them render and scroll much
  570.         faster on a screen with lots of bitplanes/colors.
  571.     Available system fonts will now be buffered for _all_ font requesters.
  572.       This speeds up font requesters enormously, a font scan is generally
  573.       needed only once now.  The version of ReqTools for Kickstart 2.0 (or
  574.       higher) has been made intelligent enough to see if the assign has been
  575.       changed between two requests.  ReqTools will free the buffer when
  576.       memory gets low.  Note that to accomplish this ReqTools keeps its
  577.       library open count 0.  A real open count is kept internally.
  578.     File requester will no longer show deferred (late) assigns.
  579.     Several bug fixes:
  580.       o Small bug: was no longer possible to exit volume/assign list by
  581.         pressing Return in the drawer gadget without changing the directory.
  582.       o Fixed weird bug with the selection of listview entries.  If you
  583.         selected a non-existing item and dragged the mouse up, an item above
  584.         all others would be complemented.  Thanks to Mathias Korsbäck for
  585.         reporting this.
  586.       o No longer goes into an endless loop when LOCALE: could not be found
  587.         when a catalog had to be loaded.  Thanks to Holger Kruse for
  588.         reporting this.
  589.       o Resizing a file requester with an inexisting directory and with the
  590.         volume list displayed resulted in a crash.
  591.       o Some other miscellaneous bugfixes.
  592.     Norwegian catalog file included (thanks Mario).
  593.     Improved and bug fixed Dice C libraries included (by Magnus Holmgren).
  594.       Includes libs for small code model, large code model and both of these
  595.       with the arguments passed in registers.
  596.     M2Amiga interface updated for ReqTools V38 by Frank Lömker.
  597.     PCQ Pascal interface to the library included, written by Chris Pressey.
  598.     Version 1.1 of RTPatch included.
  599.  
  600. *****************************************************************************
  601. RELEASE 2.1a (Library version 38.385 [1.3] - 38.1002 [2.0])
  602.  
  603.     Serious bug fixed: file requester would crash if you tried to type a
  604.       filename in a requester with a shared IDCMP port.
  605.     Some other small bug fixes.
  606.     rtGetString() and rtGetLong() will activate the string/integer gadget
  607.       when the requester window becomes active.  This should make life easier
  608.       for people using AutoPoint or other sunmouse-like utilities.
  609.     New keyboard shortcuts for file requester:  pressing Control-Up/Down will
  610.       bring you to the start/end of the directory list.
  611.     Kickstart 2.0 (or higher) version of ReqTools only: Faster directory
  612.       reading from a fast hard disk or ram disk.  The file requester now
  613.       tries to read as many files as possible in .5 seconds. If this time-out
  614.       expires, or all files have been read, the display is updated for the
  615.       first time.  After this initial time-out period the display will be
  616.       updated every .2 seconds.  This reduces the amount of rendering calls
  617.       substantially and therefore results in faster directory loading.
  618.     German catalog for preference editor included.  German strings in install
  619.       script have also been updated (by Steffen Salzmann, thanks Steffen).
  620.     Danish catalog for preference editor included (thanks Per).
  621.  
  622. *****************************************************************************
  623.  
  624. reqtools.library written by Nico François (Yes, Nico is my first name :-)
  625.  
  626. Thanks to o Kai Bolay for writing the Oberon interface,
  627.           o Frank Lömker and Michael Griebling for writing the Modula-2
  628.             interfaces,
  629.           o Jan van den Baard and Magnus Holmgren for writing the Dice C
  630.             libraries,
  631.           o Martin Steppler for writing the Manx C libraries,
  632.           o Richard Waspe and Gunter Indenhoek for writing the HighSpeed
  633.             Pascal interfaces,
  634.           o Chris Pressey for writing the PCQ Pascal interface,
  635.           o Federico Giannici for the useful suggestions,
  636.           o Peter Stuer, Gunter Indenhoek, Jorrit Tyberghein, Ives Aerts,
  637.             Bert Wynants, Mathias Korsbäck, Christoffer Zettermark and
  638.             Roger Nordin for beta-testing,
  639.           o Michele Giorato for the Italian catalog translation,
  640.           o Patrik Nordvall for the Swedish catalog translation,
  641.           o Per Jacobsen for the Danish catalog translations,
  642.           o Mario Gonzalez for the Norwegian catalog translations,
  643.           o Herman Stevens for being my Fido boss node and having such a
  644.             great Amiga BBS,
  645.           o All registered ReqTools users/developers.
  646.  
  647.  
  648. "What you got buried? In your backyard
  649.  What secret do you sleep with when the black moon comes?" - The Black Crowes
  650.  
  651.  
  652. (C) 1991/1992 Nico François
  653.  
  654.                                    //
  655.                        Thanks to \X/ Amiga for being the best computer ever !
  656.  
  657.